<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .box1 {
            width: 100%;
            /* 不设置高度 父元素由内容撑开 */
            border: 5px red solid;
        }

        /* 解决高度塌陷 伪元素 */
        .box1::after {
            content: "";
            display: block;
            clear: both;
        }



        .box2 {
            width: 100px;
            height: 100px;
            background-color: yellow;
            /* 
            当父元素高度由子元素撑开，当子元素浮动以后，父元素高度塌陷
            */
            float: left;
        }
    </style>
</head>

<body>
    <div class="box1">
        <div class="box2">5</div>
        <!-- 受浮动影响高度塌陷 解决浮动影响 -->
        <!-- 添加一个空白div清除左右两边的影响 能解决但是会添加多余的结构 -->
        <!-- <div style="clear: both;"></div> -->
    </div>

</body>

</html>